$(function() {
    var layer = layui.layer
    var form = layui.form
    var laypage = layui.laypage;
    // 定义美化事件的过滤器
    template.defaults.imports.dataFormat = function(date) {
        const dt = new Date(date)
        var y = dt.getFullYear()
        var m = padZero(dt.getMonth() + 1)
        var d = padZero(dt.getDate())
        var hh = padZero(dt.getHours())
        var mm = padZero(dt.getMinutes())
        var ss = padZero(dt.getSeconds())
        return y + '-' + m + '-' + d + '' + hh + ':' + mm + ':' + ss
    }

    function padZero(n) {
        return n > 9 ? '0' + n : n
    }

    //定义一个查询的参数对象
    var p = {
        pagenum: 1, //页码值
        pagesize: 2, //每页显示多少条数据
        cate_id: '', //	文章分类的 Id
        state: '', //文章的发布状态
    }

    initTable()
    initCate()

    function initTable() {
        $.ajax({
            method: 'GET',
            url: 'http://api-breakingnews-web.itheima.net/my/article/list',
            headers: {
                Authorization: localStorage.getItem('token')
            },
            data: p,
            success: function(res) {
                if (res.status !== 0) {
                    return layer.msg('获取文章列表失败！')
                }
                layer.msg('获取文章列表成功！')
                console.log(res);
                var htmlTable = template('tpl-Table', res)
                $('tbody').html(htmlTable)
                renderPage(res.total)
            }
        })
    }

    function initCate() {
        $.ajax({
            method: 'GET',
            url: 'http://api-breakingnews-web.itheima.net/my/article/cates',
            headers: {
                Authorization: localStorage.getItem('token')
            },
            success: function(res) {
                if (res.status !== 0) {
                    return layer.msg('获取文章分类列表失败！')
                }
                var htmlCate = template('tpl-cate', res)
                $('#cate_id').html(htmlCate)
                form.render()
            }
        })
    }

    $('#form-serach').on('submit', function(e) {
        e.preventDefault()
            // 获取表单选中项的值
        var cate_id = $('#cate_id').val()
        var state = $('#state').val()
            // 为查询参数对象q中对应的属性赋值
        p.cate_id = cate_id
        p.state = state
            // 根据最新的誜xuan条件，重新渲染表格的数据
        initTable()

    })

    // 定义渲染分页的方法
    function renderPage(total) {
        laypage.render({
            elem: 'pageBox', //分页容器的id
            count: total, //总数据条款
            limit: p.pagesize, //每页显示几条数据
            curr: p.pagenum, //设置默认被选中的分页
            layout: ['count', 'limit', 'prev', 'page', 'next', 'skip'],
            limits: [2, 3, 5, 10],
            // 分页发生切换的时候，触发jump回调
            jump: function(obj, first) {
                p.pagenum = obj.curr
                p.pagesize = obj.limit
                if (!first) {
                    initTable()
                }
            }
        })
    }

    // 通过代理的形式，为删除按钮绑定点击事件处理函数
    $('tbody').on('click', '.btn-delete', function() {
        var len = $('.btn-delete').length
        var id = $(this).attr('date-id')
        layer.confirm('确认删除？', { ico: 3, title: '提示' }, function(index) {
            $.ajax({
                method: 'GET',
                url: 'http://api-breakingnews-web.itheima.net/my/article/deletecate/' + id,
                headers: {
                    Authorization: localStorage.getItem('token')
                },
                success: function(res) {
                    if (res.status !== 0) {
                        return layer.msg('删除文章失败！')
                    }
                    layer.msg('删除文章成功！')
                    if (len === 1) {
                        p.pagenum = p.pagenum === 1 ? 1 : p.pagenum - 1
                    }
                    initTable()
                }
            })
        })
    })

})